第 1 回 


SystemVerilog や SystemC, PSI( Property Specification 
Language), アサ ーション , 機能 カバ レッ ジ , ラン ダム ・ テ スト 
生成 な ど , ここ 最近 の 検証 に 関す る " イメ ー ジ 先行 "の 流れ に と ま 
どい を 覚え る きょう この ご ろ . EDA ツー ル に 関す る 話題 な の で , 
セー ルス ・ ト ー ク で に ぎわ う 時 期 が 時 折 出 て くる の は 避け られ な 

いこ と な の か も し れ ま せん . し か し , EDA ベン ダ が 発信 する 情 
報 を 聞い て も , 設計 者 が 抱え る 実際 の 課題 へ の 指針 が つか み に く 
い の も 事実 で す . 

「 私 は また , EDA ベン ダ に だ まさ れ て いる の で し ょ うか ? 」. 
いえ いえ , た ぶん そん な つも り は な く て , た だ メッ セー ジ 性 の 強 
い 部 分 ば か り が 伝わっ た か ら だ と 思い ます . それ が , マー ケ テ ィ 
ング の 威力 な の で す . 

それ は さて お き , ここ で は これ ら の 中 か ら 「 機能 検証 」 に 関係 す 
る 部 分 , すなわち アサ ーション や 機能 カバ レッ ジ に 注目 し , それ 
ら に 対す る ユー ザ の 期待 と 現実 の ギャ ッ プ に つい て 考え て みた い 

と 思い ます . 


人 @「 アサ ーション は 短期 間 で 導入 で きる 」 と いう 誤解 

まず , 検証 対象 回 路 の 信号 の ふる まい を 定義 する アサ ー シ ョ 

に つい て 考え て み ま し ょ う . アサ ーション に 対し て , みな さん 
は どの よう な 印象 を お 持ち で し ょ う ? 

「 HDL と 親和 性 の 高い 言語 で あれ ば 導入 に か か る 期間 は 短く 
設計 技術 者 に と っ て 扱い や すい 」. この よう に 感じ て いら っ し ゃ 
る 方 が いた ら , ちょ っ と ご 用 心 .、 あ な た は アサ ーション の どこ に 
魅力 を 感じ た の で し ょ うか ?「 SystemVerilog や PSL の Verilog 
フレ ー バ な ら , 私 で も 簡単 に 書け そう 」 と いっ た と ころ で すか ? 
書け る と 思い ます . ご 心配 な く . 

た だ し , アサ ーション に よっ て 何 が 加速 され , 何 が 解決 され る 
の か を 把握 し て お く こと は 大 事 で す . ここ で は , 検証 対象 回 路 の 
0 2 の いら 
に な っ て いる こと が 前 提 と な る こと に 注意 し て くだ さい . 仕様 書 
NG お の に 0 だら か の 
よう な 言語 を 使っ て も チェ ッ ク す る こと は 無理 . 不明 瞭 な イン タ 
ー フ ェ ー ス の プロ パテ ィ を 設定 し た と ころ で , “ ザル "同然 の チェ 
ッ ク し か 行え ませ ん . 

これ は た い へ ん ! 導入 する 方 は EDA ツー ル の ライ セン ス を 気 
に する 前 に , 検証 対象 回 路 の イン ター フェ ー ス 部 に お ける 信号 の 
プロ パテ ィ が 明確 に な か っ て いる か どう か を 先 に 確認 する べき で し 
ょ う . アサ ーション を 使え ば チェ ッ ク の 効率 ば 期待 どおり ) 格段 
に 上 が り ま す . し か し , 実際 に 効率 を 上 げ る た め に は 仕様 書 の 不 
明瞭 な 部 分 を な くす 作業 が 必要 で す .「 実践 し な が ら 習得 し て い 
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け ば いい や 」 と いっ た 安易 な 気持 ち で アサ ーション を 使い 始め る 
と , 結局 .「 ツー ル や 言語 が 自動 で フォ ロー し て くれ な い 」,「 使 
い 電 の に 当 2 光 了 6D ま まき 

ツー ル は 神様 で は あり ませ ん . その 恩恵 を 受け る に は , ツー ル 
が 要求 する 条件 を 整え て や ら な けれ ば な ら な い の で す . で は , 手 
を 抜か ず 。 定義 や 設定 検証 項目 の 沈 い 出し が で きれ ば 知 期 間 で 
の 導入 ・ 立 ち 上 げ を 実現 で きる の で し ょ うか ? いえ , 一 般 に 導 
入 時 の リー ド ・ タ イム は 増え ます . これ まで や っ て いな か っ た 
( 手 を 抜い て いた ) こ と を や ら な けれ ば な ら な い の で すか ら … 


@⑯「 Verilog ベー ス だ か ら 簡単 そう 」 と いう 誤解 

次 に , 機能 カバ レッ ジ や カバ レッ ジ ・ ベ ー ス 検証 に つい て 考え 
て み ま す . 従来 か らい く つか の 機能 検証 ツー ル や 検証 言語 が 使わ 
れ て いま す が , 最近 で は SystemVerilog が この 分 野 に 参入 し て き 
まし た . 本 誌 で も 特集 され て いる の で , みな さん の 注目 度 も 上 が 
っ て いる か も し れ ま せん . 

「 だ っ て , Verilog だ も ん 」. ええ , Verilog です. し か し , 機能 
カバ レッ ジ の 概念 や 手法 を IEEE が 決め て いる わけ で は あり ませ 
ん . IEEE が 決め て いる の は 言語 規定 で す . 言語 レベ ル の 話 で あ 
れ ば , 過去 の ツー ル や 言語 も , みん な 同じ こと を 主張 し て いま す . 

「 機能 検証 は , 私 た ちの 環境 で は この よう に 実施 し て いま す . 
ちな み に 私 た ち は オ ブ ジ ェクト 指向 の 概念 を 利 し て いま す 」. あ 
れ ? ひい ちゃ いま し た か ?7 それ な ら 念 の た め , SystemVerilog 
の LRM language reference manual) を 参照 し て みて くだ さい . 
オブ ジェ クト 指向 を サポ ー ト し て いる こと が 明記 され て いま す . 
SystemVerilog の 機能 検証 の 部 祭 検証 記述 ) は , これ まで の 検 
証言 語 や 検証 環境 の 歩み を 踏襲 し た 形 で 発展 し た も の と 言え ます . 
つま り , 言語 うん ぬん より も , これ まで LSI 設 計 者 が 避け て きた 
オブ ジェ クト 指向 な どの 概念 の 導入 や 理解 が 必要 で ポ つまり , 
導入 時 の リー ド ・ タ イム が 必要 ). 少な く と も Verilog だ か ら 簡 
単 そ う 」 と いう の は 誤解 な の で す . 
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